/**
 * Copyright (c) 2015 Bosch Software Innovations GmbH and others
 *
 * This program and the accompanying materials are made
 * available under the terms of the Eclipse Public License 2.0
 * which is available at https://www.eclipse.org/legal/epl-2.0/
 *
 * SPDX-License-Identifier: EPL-2.0
 */
package org.eclipse.hawkbit.mgmt.json.model.distributionset;

import java.util.ArrayList;
import java.util.List;

import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
import com.fasterxml.jackson.annotation.JsonInclude;
import com.fasterxml.jackson.annotation.JsonInclude.Include;
import com.fasterxml.jackson.annotation.JsonProperty;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.ToString;
import lombok.experimental.Accessors;
import org.eclipse.hawkbit.mgmt.json.model.MgmtNamedEntity;
import org.eclipse.hawkbit.mgmt.json.model.softwaremodule.MgmtSoftwareModule;

/**
 * A json annotated rest model for DistributionSet to RESTful API
 * representation.
 */
@Data
@Accessors(chain = true)
@EqualsAndHashCode(callSuper = true)
@ToString(callSuper = true)
@JsonInclude(Include.NON_NULL)
@JsonIgnoreProperties(ignoreUnknown = true)
@Schema(description = """
        **_links**:
        * **type** - The type of the distribution set
        * **modules** - List of software modules
        * **metadata** - List of metadata
        """, example = """
        {
           "createdBy" : "bumlux",
           "createdAt" : 1682408574924,
           "lastModifiedBy" : "bumlux",
           "lastModifiedAt" : 1682408574925,
           "name" : "DS",
           "description" : "Updated Desc: 2LaONizh7WZp0on6XEOZI9AwEYIjj77YZskEmA2LVrKtAOXj9vvqACopEghLMqt6DIWpIahn6XM4jUlRZ1T5SZS2NWMuWHGoFIg1",
           "version" : "1.0",
           "modules" : [ {
             "createdBy" : "bumlux",
             "createdAt" : 1682408574921,
             "lastModifiedBy" : "bumlux",
             "lastModifiedAt" : 1682408574926,
             "name" : "Firmware",
             "description" : "Updated Desc: 2LaONizh7WZp0on6XEOZI9AwEYIjj77YZskEmA2LVrKtAOXj9vvqACopEghLMqt6DIWpIahn6XM4jUlRZ1T5SZS2NWMuWHGoFIg1",
             "version" : "1.0.42",
             "type" : "os",
             "typeName" : "OS",
             "vendor" : "vendor Limited Inc, California",
             "locked" : true,
             "deleted" : false,
             "encrypted" : false,
             "_links" : {
               "self" : {
                 "href" : "https://management-api.host.com/rest/v1/softwaremodules/18"
               }
             },
             "id" : 18
           }, {
             "createdBy" : "bumlux",
             "createdAt" : 1682408574920,
             "lastModifiedBy" : "bumlux",
             "lastModifiedAt" : 1682408574925,
             "name" : "app runtime",
             "description" : "Updated Desc: 2LaONizh7WZp0on6XEOZI9AwEYIjj77YZskEmA2LVrKtAOXj9vvqACopEghLMqt6DIWpIahn6XM4jUlRZ1T5SZS2NWMuWHGoFIg1",
             "version" : "1.0.25",
             "type" : "runtime",
             "typeName" : "runtime",
             "vendor" : "vendor GmbH, Stuttgart, Germany",
             "locked" : true,
             "deleted" : false,
             "encrypted" : false,
             "_links" : {
               "self" : {
                 "href" : "https://management-api.host.com/rest/v1/softwaremodules/17"
               }
             },
             "id" : 17
           }, {
             "createdBy" : "bumlux",
             "createdAt" : 1682408574919,
             "lastModifiedBy" : "bumlux",
             "lastModifiedAt" : 1682408574926,
             "name" : "application",
             "description" : "Updated Desc: 2LaONizh7WZp0on6XEOZI9AwEYIjj77YZskEmA2LVrKtAOXj9vvqACopEghLMqt6DIWpIahn6XM4jUlRZ1T5SZS2NWMuWHGoFIg1",
             "version" : "1.0.67",
             "type" : "application",
             "typeName" : "Application",
             "vendor" : "vendor Limited, California",
             "locked" : true,
             "deleted" : false,
             "encrypted" : false,
             "_links" : {
               "self" : {
                 "href" : "https://management-api.host.com/rest/v1/softwaremodules/16"
               }
             },
             "id" : 16
           } ],
           "requiredMigrationStep" : false,
           "type" : "test_default_ds_type",
           "typeName" : "OS (FW) mandatory, runtime (FW) and app (SW) optional",
           "complete" : true,
           "deleted" : false,
           "valid" : true,
           "_links" : {
             "self" : {
               "href" : "https://management-api.host.com/rest/v1/distributionsets/6"
             },
             "modules" : {
               "href" : "https://management-api.host.com/rest/v1/distributionsets/6/assignedSM?offset=0&limit=50"
             },
             "type" : {
               "href" : "https://management-api.host.com/rest/v1/distributionsettypes/24"
             },
             "metadata" : {
               "href" : "https://management-api.host.com/rest/v1/distributionsets/6/metadata?offset=0&limit=50"
             }
           },
           "id" : 6
         }""")
public class MgmtDistributionSet extends MgmtNamedEntity {

    @JsonProperty(required = true)
    @Schema(description = "The technical identifier of the entity", example = "51")
    private Long id;

    @Schema(description = "Package version", example = "1.4.2")
    private String version;

    @Schema(description = "The type of the distribution set", example = "test_default_ds_type")
    private String type;

    @Schema(description = "The type name of the distribution set",
            example = "OS (FW) mandatory, runtime (FW) and app (SW) optional")
    private String typeName;

    @Schema(description = "If the distribution set is locked", example = "true")
    private boolean locked;

    @Schema(description = "Deleted flag, used for soft deleted entities", example = "false")
    private boolean deleted;

    @Schema(description = "True by default and false after the distribution set is invalidated by the user", example = "true")
    private boolean valid;

    @Schema(description = """
            True if DS is a required migration step for another DS. As a result the DS’s assignment will not be cancelled
            when another DS is assigned (note: updatable only if DS is not yet assigned to a target)""", example = "false")
    private boolean requiredMigrationStep;

    private List<MgmtSoftwareModule> modules = new ArrayList<>();

    @Schema(description = "True of the distribution set software module setup is complete as defined by the distribution set type",
            example = "true")
    private Boolean complete;
}